

# **IECA**

**Embedded Computer Architecture** 

Lesson 14: Timers in CTC mode



### **Output Compare Unit**



toggle the port pin at match!



#### TIMER 0 and CTC mode



# Timer 0: Compare Unit (8 bit)



# Timer 0: Selecting CTC mode



#### Timer 0: Clock selection

| Bit           | 7    | 6     | 5     | 4     | 3     | 2    | 1    | 0             | _     |
|---------------|------|-------|-------|-------|-------|------|------|---------------|-------|
|               | FOC0 | WGM00 | COM01 | COM00 | WGM01 | CS02 | CS01 | C <b>S</b> 00 | TCCR0 |
| Read/Write    | W    | R/W   | R/W   | R/W   | R/W   | R/W  | R/W  | R/W           | •     |
| Initial Value | 0    | 0     | 0     | 0     | 0     | 0    | 0    | 0             |       |

| CS02 | CS01 | CS00 | Description                                             |
|------|------|------|---------------------------------------------------------|
| 0    | )0   | 0    | No clock source (Timer/Counter stopped).                |
| 0    | 0    | 1    | Clk <sub>I/O</sub> /(No prescaling)                     |
| 0    | 1    | 0    | clk <sub>I/O</sub> /8 (From prescaler)                  |
| 0    | 1    | 1    | clk <sub>I/O</sub> /64 (From prescaler)                 |
| 1    | 0    | 0    | clk <sub>I/O</sub> /256 (From prescaler)                |
| 1    | 0    | 1    | ClK <sub>I/O</sub> /1024 (From prescaler)               |
| 1    | 1    | 0    | External clock source on T0 pin. Clock on falling edge. |
| 1    | 1    | 1    | External clock source on T0 pin. Clock on rising edge.  |

### Timer 0: Output Compare



Table 39. Compare Output Mode, non-PWM Mode

| COM01 | COM00 | Description                              |
|-------|-------|------------------------------------------|
| 0     | 0     | Normal port operation, OC0 disconnected. |
| 0     | 1     | Toggle OC0 on compare match              |
| 1     | 0     | Clear OC0 on compare match               |
| 1     | 1     | Set OC0 on compare match                 |

### Timer 0: Output Compare Pin



# Test ("socrative.com": Room = MSYS)

A Mega32 CPU clock frequency is 3,6864 MHz.
 Timer 0 is initialized for CTC mode, and "Toggle OC0 on compare match" is selected.
 The Timer 0 clock prescaler is set to1024.
 What frequency can be measurered at the OC0 pin, when register OCR0 = 199?

• A: 18 Hz.

• B: 199 Hz.

• C: 1024 Hz.

• D: 9 Hz.



### TIMER 1 and CTC mode



# Timer 1: Compare Units (2 sets of 16 bit)



# Timer 1: Selecting CTC mode



See next slide!

# Timer 1: Selecting CTC mode

| Mode | WGM13 | WGM12<br>(CTC1) | WGM11<br>(PWM11) | WGM10<br>(PWM10) | Timer/Counter Mo | de of Operation  | ТОР    | Update of<br>OCR1X | TOV1 Flag Set<br>on |
|------|-------|-----------------|------------------|------------------|------------------|------------------|--------|--------------------|---------------------|
| 0    | 0     | 0               | 0                | 0                | Normal           |                  | 0xFFFF | Immediate          | MAX                 |
| 1    | 0     | 0               | 0                | 1                | PWM, Phase Corre | ct, 8-bit        | 0x00FF | TOP                | воттом              |
| 2    | 0     | 0               | 1                | 0                | PWM, Phase Corre | ct, 9-bit        | 0x01FF | TOP                | воттом              |
| 3    | 0     | 0               | 1                | 1                | PWM, Phase Corre | ct, 10-bit       | 0x03FF | TOP                | воттом              |
| 4    | 0     | 1               | 0                | 0                | стс              |                  | OCR1A  | Immediate          | MAX                 |
| 5    | 0     | 1               | 0                | 1                | Fast PWM, 8-bit  |                  | 0x00FF | TOP                | TOP                 |
| 6    | 0     | 1               | 1                | 0                | Fast PWM, 9-bit  |                  | 0x01FF | TOP                | TOP                 |
| 7    | 0     | 1               | 1                | 1                | Fast PWM, 10-bit |                  | 0x03FF | TOP                | TOP                 |
| 8    | 1     | 0               | 0                | 0                | PWM, Phase and F | requency Correct | ICR1   | воттом             | воттом              |
| 9    | 1     | 0               | 0                | 1                | PWM, Phase and F | requency Correct | OCR1A  | воттом             | воттом              |
| 10   | 1     | 0               | 1                | 0                | PWM, Phase Corre | ct               | ICR1   | TOP                | воттом              |
| 11   | 1     | 0               | 1                | 1                | PWM, Phase Corre | ct               | OCR1A  | TOP                | воттом              |
| 12   | 1     | 1               | 0                | 0                | стс              | <u> </u>         | ICR1   | Immediate          | MAX                 |
| 13   | 1     | 1               | 0                | 1                | Reserved         |                  | -      | -                  | -                   |
| 14   | 1     | 1               | 1                | 0                | Fast PWM         |                  | ICR1   | TOP                | TOP                 |
| 15   | 1     | 1               | 1                | 1                | Fast PWM         |                  | OCR1A  | TOP                | TOP                 |

Do not use this CTC mode!

#### Timer 1: Clock selection

| Bit           | 7     | 6     | 5 | 4     | 3     | 2    | 1    | U    |        |
|---------------|-------|-------|---|-------|-------|------|------|------|--------|
|               | ICNC1 | ICES1 | - | WGM13 | WGM12 | CS12 | CS11 | CS10 | TCCR1B |
| Read/Write    | R/W   | R/W   | R | R/W   | R/W   | ₩    | R/W  | R/W  |        |
| Initial Value | 0     | 0     | 0 | 0     | 0     | 0    | 0    | 0    |        |

| CS12 | CS11 | CS10 | Description                                             |
|------|------|------|---------------------------------------------------------|
| 0    | 0    | 0    | No clock source (Timer/Counter stopped).                |
| 0    | 0    | 1    | clk <sub>I/O</sub> /1 (No prescaling)                   |
| 0    | 1    | 0    | clk <sub>I/O</sub> /8 (From prescaler)                  |
| 0    | 1    | 1    | clk <sub>I/O</sub> /64 (From prescaler)                 |
| 1    | 0    | 0    | clk <sub>I/O</sub> /256 (From prescaler)                |
| 1    | 0    | 1    | clk <sub>I/O</sub> /1024 (From prescaler)               |
| 1    | 1    | 0    | External clock source on T1 pin. Clock on falling edge. |
| 1    | 1    | 1    | External clock source on T1 pin. Clock on rising edge.  |

## Timer 1: Output Compare registers



Notice: 2 16 bit registers: OCR1A and OCR1B.

These names can be used directly in AVR GCC, after #include <avr/io.h>.

# Timer 1: Waveform generators (A og B)



| Table 44. | Cor | npare | Output | Mode | non-PWM |
|-----------|-----|-------|--------|------|---------|
|-----------|-----|-------|--------|------|---------|

| COM1A1/COM1B1 | COM1A0/COM1B0 | Description                                                |
|---------------|---------------|------------------------------------------------------------|
| 0             | 0             | Normal port operation, OC1A/OC1B disconnected.             |
| 0             | 1             | Toggle OC1A/OC1B on compare match                          |
| 1             | 0             | Clear OC1A/OC1B on compare match (Set output to low level) |
| 1             | 1             | Set OC1A/OC1B on compare match (Set output to high level)  |

Red = The A system.

**Green = The B system.** 

### Timer 1: Output Compare Pins



# Test ("socrative.com": Room = MSYS)

The Mega32 Timer 1 is in CTC mode (mode 4), and the CPU clock frequency is 4 MHz.
 The Timer 1 clock prescaler = 8.
 What value must be written to register OCR1A, in order to generate a square signal at the OC1A pin with a frequency of 1000 Hz?

- A: OCR1A = 1000;
- B: OCR1A = 4000000;
- C: OCR1A = 249;
- D: OCR1A = 999;



### TIMER 2 and CTC mode



# Timer 2: Compare Unit (8 bit)



# Timer 2 : Selecting CTC mode



| Mode | WGM21<br>(CTC2) | WGM20<br>(PWM2) | Timer/Counter Mode of<br>Operation | ТОР  | Update of OCR2 | TOV2 Flag<br>Set on |
|------|-----------------|-----------------|------------------------------------|------|----------------|---------------------|
| 0    | 0               | 0               | Normal                             | 0xFF | Immediate      | MAX                 |
| 1    | 0               | 1               | PWM, Phase Correct                 | 0xFF | TOP            | воттом              |
| 2    | 1               | 0               | стс                                | OCR2 | Immediate      | MAX                 |
| 3    | 1               | 1               | Fast PWM                           | 0xFF | TOP            | MAX                 |

#### Timer 2: Clock selection

| Bit           | 7    | 6     | 5     | 4                                        | 3         | 2       |              | 0     |       |
|---------------|------|-------|-------|------------------------------------------|-----------|---------|--------------|-------|-------|
|               | FOC2 | WGM20 | COM21 | COM20                                    | WGM21     | C\$22   | C <b>S21</b> | C\$20 | TCCR2 |
| Read/Write    | W    | R/W   | R/W   | R/W                                      | R/W       | R/W     | R/W          | R/W   |       |
| Initial ∀alue | 0    | 0     | 0     | 0                                        | 0         | 0       | 0            | 0     |       |
|               |      |       |       |                                          |           |         |              |       |       |
| CS22          | CS21 | CS20  | De    | scription                                |           |         |              |       |       |
| 0             | 0    | 0     | No    | No clock source (Timer/Counter stopped). |           |         |              |       |       |
| 0             | 0    | 1     | clk   | clk <sub>T2S</sub> /(No prescaling)      |           |         |              |       |       |
| 0             | 1    | 0     | clk   | <sub>T2S</sub> /8 (Fro                   | m presca  | aler)   |              |       |       |
| 0             | 1    | 1     | clk   | clk <sub>T2S</sub> /32 (From prescaler)  |           |         |              |       |       |
| 1             | 0    | 0     | clk   | clk <sub>T2S</sub> /64 (From prescaler)  |           |         |              |       |       |
| 1             | 0    | 1     | clk   | clk <sub>T2S</sub> /128 (From prescaler) |           |         |              |       |       |
| 1             | 1    | 0     | clk   | clk <sub>T2s</sub> /256 (From prescaler) |           |         |              |       |       |
| 1             | 1    | 1     | clk   | <sub>T2s</sub> /1024                     | (From pre | scaler) |              |       |       |

### Timer 2: Output Compare



Table 51 Compare Output Mode, non-PWM Mode

| COM21 | COM20 | Description                              |
|-------|-------|------------------------------------------|
| 0     | 0     | Normal port operation, OC2 disconnected. |
| 0     | 1     | Toggle OC2 on compare match              |
| 1     | 0     | Clear OC2 on compare match               |
| 1     | 1     | Set OC2 on compare match                 |

### Timer 2: Output Compare Pin



### End of lesson 14

